﻿<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<html>
<head>
<title>DI_COMBOBOX</title>
<meta http-equiv="Content-Type" Content="text/html; charset=utf-8">
<link rel="stylesheet" type="text/css" href="../../../styles/styles.css">
<script language="javascript" src='../../links.js' type="text/javascript"></script>
</head>
<body>

<h1>DI_COMBOBOX</h1>
<div class=navbar>
<a href="../../index.html">главная</a> |
<a href="index.html">элементы диалога</a> |
<a href="../index.html">Dialog API</a>
</div>

<div class=shortdescr>
Элемент диалога <code>DI_COMBOBOX</code> описывает поле ввода со списком (комбинированный список).
</div>

<pre class=syntax>
struct FarDialogItem
{
  enum FARDIALOGITEMTYPES Type = <b>DI_COMBOBOX</b>
  intptr_t X1                  = <b>X1</b>
  intptr_t Y1                  = <b>Y</b>
  intptr_t X2                  = <b>X2</b>
  intptr_t Y2                  = <b>Y</b> (равен значению Y1)
  struct FarList *ListItems    = <b>ListItems</b>
  FARDIALOGITEMFLAGS Flags     = <b>Flags</b>
  const wchar_t *Data          = <b>редактируемый текст</b>
};
</pre>

<p class=note><img src="../../../images/note.gif" alt="Внимание!" width="10" height="10"> Внимание!</p>
<UL class=note><LI>Приведено схематичное изображение структуры; полное описание структуры <a href="../../structures/fardialogitem.html">см. здесь</a>.</LI></UL>

<h3>ListItems</h3>
<div class=descr>
<p>Указатель на структуру <a href="../../structures/farlist.html">FarList</a>, описывающую пункты для начальной инициализации комбинированного списка.
Редактируемое поле заполняется значением первого пункта списка с установленным флагом <a href="../../structures/farlistitem.html#LIF_SELECTED">LIF_SELECTED</a>
при условии, что <code>Data</code> не содержит "<em>редактируемый текст</em>" и есть хотя бы один элемент списка с таким флагом. Если таких пунктов несколько, берётся первый.
<p>Если значение равно <code>NULL</code>, то список выводится не будет.
</div>

<h3>Флаги</h3>
<div class=descr>
Для элемента <code>DI_COMBOBOX</code> имеют значения следующие флаги (про флаги списка см. <a href="../../structures/farlistitem.html">FarListItem</a>):
<table class="cont">
<tr class="cont"><th class="cont" width="40%">Флаг</th><th class="cont" width="60%">Описание</th></tr>
<tr class="cont"><td class="cont" width="40%"><a href="../flags/dif_defaultbutton.html">DIF_DEFAULTBUTTON</a></td>
<td class="cont" width="60%">флаг, означающий, что данный элемент диалога является "элементом по умолчанию"</td></tr>
<tr class="cont"><td class="cont" width="40%"><a href="../flags/dif_focus.html">DIF_FOCUS</a></td>
<td class="cont" width="60%">определяет, что при показе диалога установить клавиатурный фокус ввода на данный элемент</td></tr>
<tr class="cont"><td class="cont" width="40%"><a href="../flags/dif_dropdownlist.html">DIF_DROPDOWNLIST</a></td>
<td class="cont" width="60%">стиль не редактируемого раскрывающегося списка - DropDownList</td></tr>
<tr class="cont"><td class="cont" width="40%"><a href="../flags/dif_editexpand.html">DIF_EDITEXPAND</a></td>
<td class="cont" width="60%">"расширять" переменные среды</td></tr>
<tr class="cont"><td class="cont" width="40%"><a href="../flags/dif_editpath.html">DIF_EDITPATH</a></td>
<td class="cont" width="60%">строка ввода будет содержать имена реальных файловых объектов</td></tr>
<tr class="cont"><td class="cont" width="40%"><a href="../flags/dif_listautohighlight.html">DIF_LISTAUTOHIGHLIGHT</a></td>
<td class="cont" width="60%">горячие клавиши будут назначены автоматически</td></tr>
<tr class="cont"><td class="cont" width="40%"><a href="../flags/dif_listnoampersand.html">DIF_LISTNOAMPERSAND</a></td>
<td class="cont" width="60%">показывать горячие клавиши в списке</td></tr>
<tr class="cont"><td class="cont" width="40%"><a href="../flags/dif_listwrapmode.html">DIF_LISTWRAPMODE</a></td>
<td class="cont" width="60%">"заворачивает" список при навигации по списку</td></tr>
<tr class="cont"><td class="cont" width="40%"><a href="../flags/dif_disable.html">DIF_DISABLE</a></td>
<td class="cont" width="60%">элемент является недоступным</td></tr>
<tr class="cont"><td class="cont" width="40%"><a href="../flags/dif_readonly.html">DIF_READONLY</a></td>
<td class="cont" width="60%">переводит строки редактирования в состояние "только для чтения"</td></tr>
<tr class="cont"><td class="cont" width="40%"><a href="../flags/dif_selectonentry.html">DIF_SELECTONENTRY</a></td>
<td class="cont" width="60%">выделить редактируемый текст при получении фокуса ввода</td></tr>
<tr class="cont"><td class="cont" width="40%"><a href="../flags/dif_nofocus.html">DIF_NOFOCUS</a></td>
<td class="cont" width="60%">управляющий элемент не получает клавиатурный фокус ввода</td></tr>
</table>
</div>

<h3>События</h3>
<div class=descr>
<table class="cont">
<tr class="cont"><th class="cont" width="40%">Событие</th><th class="cont" width="60%">Описание</th></tr>
<tr class="cont"><td class="cont" width="40%"><a href="../dmsg/dn_drawdlgitem.html">DN_DRAWDLGITEM</a></td>
<td class="cont" width="60%">начало отрисовки текстовой строки</td></tr>
<tr class="cont"><td class="cont" width="40%"><a href="../dmsg/dn_ctlcolordlgitem.html">DN_CTLCOLORDLGITEM</a></td>
<td class="cont" width="60%">запрос цветовых атрибутов для отрисовки строки редактирования комбинированного списка; <code>Param2</code>:
<pre>
<code>Colors[0]</code> - редактируемый текст
                (<a href="../../defs/farcolors.html#COL_WARNDIALOGEDIT">COL_WARNDIALOGEDIT</a> или <a href="../../defs/farcolors.html#COL_DIALOGEDIT">COL_DIALOGEDIT</a>)
<code>Colors[1]</code> - выделенный текст
                (<a href="../../defs/farcolors.html#COL_DIALOGEDITSELECTED">COL_DIALOGEDITSELECTED</a>)
<code>Colors[2]</code> - неизмененный текст (UnChanged)
                (<a href="../../defs/farcolors.html#COL_DIALOGEDITUNCHANGED">COL_DIALOGEDITUNCHANGED</a>)
<code>Colors[3]</code> - цвет символа для вызова списка
                (<a href="../../defs/farcolors.html#COL_DIALOGTEXT">COL_DIALOGTEXT</a>)

<code>Param2</code> (при флаге <a href="../flags/dif_dropdownlist.html">DIF_DROPDOWNLIST</a>):

<code>Colors[0]</code> - редактируемый текст
                (<a href="../../defs/farcolors.html#COL_WARNDIALOGEDIT">COL_WARNDIALOGEDIT</a> или <a href="../../defs/farcolors.html#COL_DIALOGEDIT">COL_DIALOGEDIT</a>)
<code>Colors[1]</code> - выделенный текст
                (<a href="../../defs/farcolors.html#COL_DIALOGEDIT">COL_DIALOGEDIT</a>
            элемент в фокусе
                <a href="../../defs/farcolors.html#COL_DIALOGEDITSELECTED">COL_DIALOGEDITSELECTED</a>)
<code>Colors[2]</code> - неизмененный текст (UnChanged)
                (<a href="../../defs/farcolors.html#COL_WARNDIALOGEDIT">COL_WARNDIALOGEDIT</a> или <a href="../../defs/farcolors.html#COL_DIALOGEDIT">COL_DIALOGEDIT</a>)
<code>Colors[3]</code> - цвет символа для вызова списка
                (<a href="../../defs/farcolors.html#COL_DIALOGTEXT">COL_DIALOGTEXT</a>)</pre>
</td></tr>
<tr class="cont"><td class="cont" width="40%"><a href="../dmsg/dn_ctlcolordlglist.html">DN_CTLCOLORDLGLIST</a></td>
<td class="cont" width="60%">запрос цветовых атрибутов перед отрисовкой открытого комбинированного списка</td></tr>
<tr class="cont"><td class="cont" width="40%"><a href="../dmsg/dn_controlinput.html">DN_CONTROLINPUT</a></td>
<td class="cont" width="60%">нажали клавиатурную клавишу или кликнули клавишей мыши</td></tr>
<tr class="cont"><td class="cont" width="40%"><a href="../dmsg/dn_listhotkey.html">DN_LISTHOTKEY</a></td>
<td class="cont" width="60%">пользователь для смены пункта в открытом комбинированном списке воспользовался горячими клавишами</td></tr>
<tr class="cont"><td class="cont" width="40%"><a href="../dmsg/dn_editchange.html">DN_EDITCHANGE</a></td>
<td class="cont" width="60%">текст изменён</td></tr>
<tr class="cont"><td class="cont" width="40%"><a href="../dmsg/dn_killfocus.html">DN_KILLFOCUS</a></td>
<td class="cont" width="60%">элемент потерял фокус (при условии, что не используется флаг <a href="../flags/dif_nofocus.html">DIF_NOFOCUS</a>)</td></tr>
<tr class="cont"><td class="cont" width="40%"><a href="../dmsg/dn_gotfocus.html">DN_GOTFOCUS</a></td>
<td class="cont" width="60%">элемент получил фокус (при условии, что не используется флаг <a href="../flags/dif_nofocus.html">DIF_NOFOCUS</a>)</td></tr>
</table>
</div>

<h3>Замечания</h3>
<div class=descr>
Работа со списками <code>DI_COMBOBOX</code> и <code>DI_LISTBOX</code> организована по следующей схеме:
<ul>
<li>Запуск DialogInit<br>
    FarDialogItem.Param.ListItems - только для начальной инициализации.
    <br><br>
<li>DM_LISTADD<br>
    Добавляет только пункт списка, без ассоциированных данных
    <br><br>
<li>DM_LISTINSERT<br>
    Вставляет только пункт списка, без ассоциированных данных
    <br><br>
<li>DM_LISTUPDATE<br>
    Удаляет UserData для обновляемого пункта списка.<br>
    Только обновление данных пункта списка без ассоциированных данных
    <br><br>
<li>DM_LISTSETDATA<br>
    Перед установкой новых ассоциированных данных предыдущие
    уничтожаются (если было выделение по памяти)
    <br><br>
<li>DM_LISTGETDATA<br>
    Возвращается значение, предварительно установленное DM_LISTSETDATA.
    <br><br>
<li>DM_LISTGETDATASIZE<br>
    Возвращается размер ассоциированных данных.
    <br><br>
<li>DM_LISTGETITEM<br>
    Возвращает только пункт списка, без ассоциированных данных.
    <br><br>
<li>Завершение DialogFree<br>
    Ассоциированные данные уничтожаются (если было выделение по памяти)
    <br><br>
</ul>
</div>

<div class=see>Смотрите также:</div>
<div class=seecont>
<a href="di_listbox.html">DI_LISTBOX</a>,
<a href="../../structures/fardialogitem.html">FarDialogItem</a>
</div>

</body>
</html>